package com.itheima.controller;

import com.itheima.anno.Log;
import com.itheima.pojo.Dept;
import com.itheima.pojo.Result;
import com.itheima.service.DeptService;
import lombok.extern.slf4j.Slf4j;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.*;

import java.util.List;

/**
 * 部门管理Controller
 */
@Slf4j
@RestController
@RequestMapping("/depts")
public class DeptController {

    //private static Logger log = LoggerFactory.getLogger(DeptController.class);
    @Autowired
    private DeptService deptService;

    //@RequestMapping(value = "/depts", method = RequestMethod.GET)
    // 查询全部部门
    @GetMapping
    public Result list(){
        log.info("查询全部部门数据");
        List<Dept> deptList = deptService.list();
        return Result.success(deptList);
    }

    // 根据ID删除部门
    @Log
    @DeleteMapping("/{id}")
    public Result delete(@PathVariable Integer id) throws Exception {
        log.info("根据ID删除部门数据:{}", id);
        deptService.delete(id);
        return Result.success();
    }

    // 添加部门
    @Log
    @PostMapping
    public Result add(@RequestBody Dept dept)
    {
        log.info("新增部门: {}", dept);
        deptService.add(dept);
        return Result.success();
    }

    // 根据ID查询部门
    @GetMapping("/{id}")
    public Result get(@PathVariable Integer id)
    {
        log.info("根据ID查询部门:{}", id);
        Dept dept = deptService.get(id);
        return Result.success(dept);
    }

    // 修改部门
    @Log
    @PutMapping
    public Result update(@RequestBody Dept dept)
    {
        log.info("修改部门: {}", dept);
        deptService.update(dept);
        return Result.success();
    }
}
